SwiftUI Foreach中如何使用Toggle组件

您所在的位置:网站首页 ios 组件设置 SwiftUI Foreach中如何使用Toggle组件

SwiftUI Foreach中如何使用Toggle组件

2023-03-23 07:38| 来源: 网络整理| 查看: 265

最近有一个需求,在一个界面中显示一个列表,列表中多个cell的右边要显示一个Toggle,也就是UIKit中的UISwitch开关,我们知道Toggle组件需要绑定一个变量的,但是列表数据是从服务器取的,要用多少个Toggle组件不可知,所以如何记住这些Toggle的值呢?

如果用一个变量绑定所有的Toggle,那么这些Toggle就是同开同关了,显然不行。下面来看一下具体实现。

Foreach组件

Foreach组件是SwiftUI中的一个非常强大的组件。它可以用来遍历一个集合,并为集合中的每个元素创建一个视图。以下是一个使用Foreach组件的示例:

struct ContentView: View { let books = ["Book1", "Book2", "Book3"] var body: some View { ForEach(books, id: \.self) { book in Text(boks) } } }

在上面的示例中,我们创建了一个名为books的字符串数组,并使用Foreach组件遍历了该数组。我们还指定了id参数,用于确定集合中每个元素的唯一性。

Toggle组件

Toggle组件是SwiftUI中的另一个非常有用的组件。它可以用来创建一个开关,使用户可以切换某个设置的状态。以下是一个使用Toggle组件的示例:

struct ContentView: View { @State var isOn = false var body: some View { Toggle("Toggle", isOn: $isOn) } }

在上面的示例中,我们创建了一个名为isOn的布尔值状态,并使用Toggle组件来创建了一个开关。我们还使用了$符号来绑定Toggle组件的值到我们的状态变量上。

在Foreach中使用Toggle组件

现在我们已经了解了如何在SwiftUI中使用Foreach和Toggle组件,让我们来看看如何将它们结合起来。以下是一个在Foreach中使用Toggle组件的示例:

struct ContentView: View { @State var books = [ BookModel(name: "Book1", isSelected: false), BookModel(name: "Book2", isSelected: false), BookModel(name: "Book3", isSelected: false) ] var body: some View { VStack { ForEach(0..


【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3